## CS220: Lab#10B

1. [10 marks] Implement an instruction memory that has width 32 bits and has 11 rows. Initialize the contents of the memory using the following MIPS instruction sequence translated from the C statements shown alongside. All numerical values are represented in decimal in the following program. Each row of memory will store the binary encoding of one MIPS instruction. Use an initial block to store the instructions in instruction memory.

```
C statements
                             MIPS translation
int a, b, c, i, sum;
a = -20;
                                                  // opcode: 0x23
                             lw
                                    $1, 0($0)
b = 10;
                                    $2, 1($0)
                             lw
c = 2;
                                    $3, 2($0)
                             lw
sum = 0;
                             addiu $4, $0, 0
                                                  // opcode: 0x9
for (i=a; i<b; i+=c) {
                             addiu $5, $1, 0
   sum += i;
                             slt
                                    $6, $5, $2
                                                  // opcode: 0x0, func: 0x2a
                             beq
                                    $6, $0, exit // opcode: 0x4, encode exit as 5
}
                             addu $4, $4, $5
                                                  // opcode: 0x0, func: 0x21
                      loop:
                             addu $5, $5, $3
                                    $6, $5, $2
                             slt
                                    $6, $0, loop // opcode: 0x5, encode loop as -3
                             bne
                      exit:
```

Implement a data memory of width eight bits and having three rows for storing a, b, c. Use an initial block for storing a, b, c in eight-bit two's complement representation in the data memory. We will design a simple MIPS processor that can execute all instructions shown in this program (lw, addiu, slt, beq, addu, bne) and ignores all overflows. The "word" for this processor is eight bits long. The processor will have a register file having 32 registers each of width eight bits. Initialize all registers to zero. In all I-format instructions, the least significant eight bits of the 16-bit immediate operand will be used in the actual operation. Initialize an eight-bit program counter register to zero. In beq and bne, the program counter of the branch target should be computed by adding the least significant eight bits of the offset to the program counter of the branch instruction. In lw, the computed address should be treated as the row number of data memory. The MIPS processor is implemented as a seven-state FSM as outlined below. Initially, the state is zero. Each state's operations are done on posedge of clock.

- State 0: reads the instruction from the instruction memory row pointed to by the program counter and sets state to 1.
- State 1: finds out the fields of the instruction and sets state to 2.
- State 2: reads the source register operands of the instruction from the register file and sets state to 3.
- State 3: executes the instruction if the instruction is addiu, addu, slt, beq, or bne; if the instruction is lw, its address is computed; otherwise marks the instruction as invalid. Sets the program counter of the next instruction appropriately. Sets state to 4.
- State 4: accesses data memory if the instruction is lw and reads the row pointed to by the address computed in the last state; other instructions do nothing in this state. Sets state to 5.

- State 5: if the instruction is not marked invalid and produces a result in a destination register and the destination register is not \$0, writes the result of the instruction to the destination register. Sets state to 0 if program counter is less than 'MAX\_PC; otherwise sets state to 6. MAX\_PC should be defined as 11.
- State 6: shows the contents of register 'OUTPUT\_REG in the LEDs (LED7 is the most significant bit) and stays in state 6. OUTPUT\_REG should be defined as 4 for this program because \$4 will have the value of sum, which is of interest to us.

Your design should work for arbitrary initial values of a, b, c.

**Note to TAs for grading:** Please test the implementation by initializing a, b, c. At the time of grading, give your initial setting to the group and ask them to appropriately change the data memory contents in their code. Please have a few of the numbers as negative (you can go up to -128 on the negative side and 127 on the positive side). Also, note that the sum must be in the range -128 to 127. So, choose your data memory contents accordingly to avoid overflow. Please have different initial settings when evaluating different groups.